package com.qqn.kuangbiao.class3_20;

/**
 * 给你一个数组 nums 和一个值 val，你需要 原地 移除所有数值等于 val 的元素。
 * 元素的顺序可能发生改变。然后返回 nums 中与 val 不同的元素的数量。
 * 假设 nums 中不等于 val 的元素数量为 k，要通过此题，您需要执行以下操作：
 * 更改 nums 数组，使 nums 的前 k 个元素包含不等于 val 的元素。nums 的其余元素和 nums 的大小并不重要。
 * 返回 k。
 */
public class algorithm02 {
    // mid 变量的定义争取最小作用域有效 所以尽量不要写在循环外面
    public int removeElement(int[] nums, int val) {
        int L = 0;
        int R = nums.length - 1;
        while (L <= R) {
            if (nums[L] == val) {
                nums[L] = nums[R];
                R--;
            } else {
                L++;
            }
        }
        return L;
    }

    public static void main(String[] args) {

    }
}
